package com.bond.common.util;

import com.bond.common.page.PageDomain;
import com.bond.common.page.TableSupport;
import com.github.pagehelper.PageHelper;
import org.springframework.util.StringUtils;

/**
 * 分页工具类
 *
 * @author ruoyi
 */
public class PageUtils extends PageHelper {
    /**
     * 设置请求分页数据
     */
    public static void startPage() {
        PageDomain pageDomain = TableSupport.buildPageRequest();
        Integer pageNum = pageDomain.getPageNum();
        Integer pageSize = pageDomain.getPageSize();
        String orderBy = escapeOrderBySql(pageDomain.getOrderBy());
        Boolean reasonable = pageDomain.getReasonable();
        PageHelper.startPage(pageNum, pageSize, orderBy).setReasonable(reasonable);
    }

    /**
     * 仅支持字母、数字、下划线、空格、逗号、小数点（支持多个字段排序）
     */
    public static String SQL_PATTERN = "[a-zA-Z0-9_\\ \\,\\.]+";

    /**
     * 检查字符，防止注入绕过
     */
    public static String escapeOrderBySql(String value) {
        if (!StringUtils.isEmpty(value)) {
            if (!value.matches(SQL_PATTERN)) {
                throw new RuntimeException("参数不符合规范，不能进行查询");
            }
            if (value.length() > 300) {
                throw new RuntimeException("参数已超过最大限制，不能进行查询");
            }
        }
        return value;
    }

    /**
     * 清理分页的线程变量
     */
    public static void clearPage() {
        PageHelper.clearPage();
    }
}
